package com.algorithm.homework.hard;

/**
 * 45. 跳跃游戏 II
 *
 * <p>给定一个非负整数数组，你最初位于数组的第一个位置。
 *
 * <p>数组中的每个元素代表你在该位置可以跳跃的最大长度。
 *
 * <p>你的目标是使用最少的跳跃次数到达数组的最后一个位置。
 *
 * <p>示例:
 *
 * <p>输入: [2,3,1,1,4] 输出: 2 解释: 跳到最后一个位置的最小跳跃数是 2。   从下标为 0 跳到下标为 1 的位置，跳 1 步，然后跳 3 步到达数组的最后一个位置。
 * 说明:
 *
 * <p>假设你总是可以到达数组的最后一个位置。
 *
 * <p>来源：力扣（LeetCode） 链接：https://leetcode-cn.com/problems/jump-game-ii
 * 著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
 *
 * @author frank woo(吴峻申) <br>
 *     email:<a href="mailto:frank_wjs@hotmail.com">frank_wjs@hotmail.com</a> <br>
 * @date 2020/7/13 11:09<br>
 */
public class JumpGameII {
  public int jump(int[] nums) {
    int myHighestPosition = 0;
    int remarkPosition = 0;
    int mustChangeTime = 0;
    for (int i = 0; i < nums.length - 1; i++) {
      remarkPosition = Math.max(remarkPosition, nums[i] + i);
      if (i == myHighestPosition) {
        myHighestPosition = remarkPosition;
        mustChangeTime++;
      }
    }
    return mustChangeTime;
  }
}
